草庐IT

java - Spring MVC后台进程

全部标签

ruby-on-rails - 使用 Rails 运行多个后台并行作业

在我的RubyonRails应用程序中,我需要并行执行50个后台作业。每个作业都会创建一个到不同服务器的TCP连接,提取一些数据并更新事件记录对象。我知道执行此任务的不同解决方案,但其中任何一个都是并行的。例如,delayed_job(DJ)可能是一个很好的解决方案,只要它可以并行执行所有作业。有什么想法吗?谢谢。 最佳答案 实际上可以运行多个delayed_jobworker。来自http://github.com/collectiveidea/delayed_job:#Runstwoworkersinseparateproces

ruby - OS X 中作为守护进程运行的脚本的菜单栏图标?

我有一个ruby​​脚本(https://github.com/daemonza/MacBak)作为守护进程在我的macbook上运行并监视一堆目录的文件更改和rsync发生的任何更改。我想知道我能否让它在顶部的菜单栏中创建一个图标?只是为了让我知道它确实在运行,而不必使用ps检查它。也许以后如果需要的话,我可能希望能够从那里控制脚本,简单的带有停止和状态条目的下拉菜单等。从ObjectC看来我可以调用NSStatusItem来获取图标,但我真的只是想通过我的Ruby脚本轻松地完成它。也许我可以做一些applescript调用? 最佳答案

ruby-on-rails - 构建一个集成我的 rails 环境的 ruby​​ 守护进程

我需要构建一个将使用freeswitcher的ruby​​守护进程freeswitch的eventmachine库。几天以来,我一直在网上寻找构建ruby​​守护程序的最佳解决方案,该守护程序将集成我的Rails环境,特别是我的事件记录模型。我看过优秀的RyanBates截屏视频(第129集自定义守护程序),但我不确定这是否仍然是一个实际的解决方案。我如何以好的方式做到这一点? 最佳答案 我一直在为我的Rails环境构建守护进程。守护进程gem确实完成了所有工作。作为示例,这是从我最新的Rails应用程序(script/yourda

ruby-on-rails - 了解为什么 ruby​​ 进程在 100% CPU 时阻塞的方法

我们有一个大型Rails应用程序,几天后,我们的ruby​​进程似乎陷入循环并占用100%的CPU,直到乘客服务器死机并引发502错误。您知道找出原因的最佳方法吗?我已经尝试过NewRelic,但它只是性能方面的东西,而且我们的错误太多了,无法猜测问题出在哪里。(我们每天有很多请求和很多UTF-8BSON错误,因为我们使用的是UTF-8url)使用:Rails3.2.6和Ruby1.9.2p290乘客3.0.13MongoDB2.0.1和Mongoid2.4.11NginxFreeBSD8.2 最佳答案 找出ruby卡住位置的简便方

c# - 为什么 C# ProcessStartInfoRedirectStandardOutput 会导致 xcopy 进程失败

这有点痛苦,因为我现在面前没有代码,但我会尽力解释。我有一个启动Ruby脚本的简单C#应用程序(它还做了一些其他事情,因此它生成了一个批处理文件并执行了)。我正在使用C#进程对象并设置了以下内容重定向标准输出=真重定向标准错误=真UseShellExecute=falseCreateNoWindow=true(可爱的倒退逻辑!)然后我创建两个线程并为错误流和输出流轮询ReadLine(),等待它们完成后再调用WaitForExit()。现在,无论我做什么,当我重定向输出时,我的Ruby脚本都无法调用system("xcopy...")命令(没有生成错误,它只是不复制)。它也不会复制我要

ruby - 后台工作人员在 Rails 应用程序中查看通信

假设我有一个包含帖子的博客应用程序。创建帖子后,将创建一个工作人员来处理一些后台操作。我的情况是,在提交表单后我想显示某种加载消息(gif加载器等),当工作人员完成时我想隐藏加载消息并显示工作人员提供的一些数据。我的问题是,传达工作人员已完成工作并将其显示在用户前端的最佳方式是什么。worker回调看起来像这样defworker_finish#messagetheuserend 最佳答案 我认为您可能忽略了拥有后台工作人员的意义,基本上,您试图做的是弄巧成拙。--如果用户提交表单并且你在你的Controller中排队作业,只是为了让

ruby popen3 -- 如何在不重新打开进程的情况下重复写入 stdin 和读取 stdout?

我正在使用Open3的popen3启动在类似控制台中运行的进程的方法/REPL重复接受输入并返回输出的方式。我可以打开流程、发送输入并接收输出,代码如下:Open3.popen3("console_REPL_process")do|stdin,stdout,stderr,wait_thr|stdin.puts"astringofinput"stdin.close_writestdout.each_line{|line|putsline}#successfullyprintsalltheoutputend我想连续多次这样做,而不是重新打开进程,因为启动需要很长时间。我知道我必须关闭std

ruby - 在 JRuby 中,如何确定导致 java.lang.ThreadDeath 的原因?

在为一些与JRuby中的临时文件交互的代码运行单元测试时,我有时会得到以下信息:Exception:java.lang.ThreadDeaththrownfromtheUncaughtExceptionHandlerinthread"Thread-6395"它似乎没有引起任何问题,但这是怎么回事,我如何确定它发生在哪里?我尝试打开-d,但这并没有给我异常的堆栈跟踪。 最佳答案 FWIW:这可能与http://jira.codehaus.org/browse/JRUBY-7074有关.我偶尔会在不使用反引号但调用系统的JRuby程序中

ruby-on-rails - 工头不会杀死进程

对于启动应用程序,我使用Foreman。工头从Procfile开始流程web:bundleexecrailsserverthin-p$PORTworker:bundleexecrakeenvironmentresque:workQUEUE=send_mailapi:bundleexecrailsserverthin-p$PORT如果我在运行foreman的控制台中按control+C,则foreman结束但运行的进程未被终止。是否有可能在工头被杀死时杀死工头运行的进程。 最佳答案 下面的示例假设使用的端口是4567,然后执行:lso

ruby-on-rails - 杀死工头产生的进程

我有以下Procfile:web:bundleexecunicorn-p$PORT-c./config/unicorn.rbredis:bundleexecredis-server/usr/local/etc/redis.confworker:bundleexecsidekiq运行$foremanstart启动Unicorn、Redis和Sidekiq,但我应该如何停止它们?杀死工头会使这三个人都离开。我可以使用ps看到这个:$psaux|grepredis|grep-vgrepme615600.00.025067841740s000S+9:36am0:01.28redis-serve